# Programmable Interval Timer - 8254

### Features

- Three Independent 16-Bit Counters,
- Clock input upto 10 MHz,
- Status Read-Back Command,
- Six Programmable Counter Modes,
- Binary or BCD Counting,
- Single +5V Supply

## Pin Diagram



| T .              |       | •   | •    |
|------------------|-------|-----|------|
| P <sub>1</sub> n | Descr | 1pt | 1011 |

|   | •                               |            | Pin Description |                                                                                                                                                            |                                                                    |                                                     |  |  |
|---|---------------------------------|------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-----------------------------------------------------|--|--|
|   | Symbol                          | Pin<br>No. | Туре            |                                                                                                                                                            | Name and Function                                                  |                                                     |  |  |
|   | D <sub>7</sub> -D <sub>0</sub>  | 1-8        | 1/0             | DATA: Bi-directional three state data bus lines, connected to system data bus.                                                                             |                                                                    |                                                     |  |  |
|   | CLK 0                           | 9          | 1               | CLOCK 0: Clock input of Counter 0.                                                                                                                         |                                                                    |                                                     |  |  |
|   | OUT 0                           | 10         | 0               | OUTPUT 0: Output of Counter 0.                                                                                                                             |                                                                    |                                                     |  |  |
|   | GATE 0                          | 11         | L               | GATE                                                                                                                                                       | GATE 0: Gate input of Counter 0.  GROUND: Power supply connection. |                                                     |  |  |
|   | GND                             | 12         |                 |                                                                                                                                                            |                                                                    |                                                     |  |  |
|   | V <sub>CC</sub>                 | 24         |                 | POWER: +5V power supply connection.                                                                                                                        |                                                                    |                                                     |  |  |
|   | WR                              | 23         | · <b>!</b>      | WRITE CONTROL: This input is low during CPU write operations.                                                                                              |                                                                    |                                                     |  |  |
|   | RD                              | 22         |                 | READ CONTROL: This input is low during CPU read operations.                                                                                                |                                                                    |                                                     |  |  |
|   | <del>CS</del>                   | 21         | İ               | CHIP SELECT: A low on this input enables the 8254 to respond to RD and WR signals. RD and WR are ignored otherwise.                                        |                                                                    |                                                     |  |  |
|   | A <sub>1</sub> , A <sub>0</sub> | 20-19      | l               | ADDRESS: Used to select one of the three Counters or the Control Word Register for read or write operations. Normally connected to the system address bus. |                                                                    |                                                     |  |  |
|   |                                 |            |                 | A <sub>1</sub>                                                                                                                                             | Ao                                                                 | Selects                                             |  |  |
|   |                                 |            |                 | 0<br>0<br>1<br>1                                                                                                                                           | 0<br>1<br>0<br>1                                                   | Counter 0 Counter 1 Counter 2 Control Word Register |  |  |
|   | CLK 2                           | 18         | 1               | CLOCK 2: Clock input of Counter 2.                                                                                                                         |                                                                    |                                                     |  |  |
|   | OUT 2                           | 17         | 0               | OUT 2: Output of Counter 2.                                                                                                                                |                                                                    |                                                     |  |  |
| _ | GATE 2                          | 16         | ı               | GATE                                                                                                                                                       | 2: Gate                                                            | e input of Counter 2.                               |  |  |
| - | CLK 1                           | 15         | 1               | CLOCK 1: Clock input of Counter 1.                                                                                                                         |                                                                    |                                                     |  |  |
|   | GATE 1                          | 14         | 1               | GATE                                                                                                                                                       | GATE 1: Gate input of Counter 1.                                   |                                                     |  |  |
|   | OUT 1                           | 13         | 0               | OUT                                                                                                                                                        | OUT 1: Output of Counter 1.                                        |                                                     |  |  |

## Block Diagram of 8254

#### Internal structure



## Internal Blocks of Counter

- Count Register (CR) to store count (CRL & CRM),
- Counting elements (CE) are used for counting,
- Output Latch (OLL & OLM) to latch the count in CE,
- The Control Word Register is not part of the Counter itself, but its contents determine how the Counter operates.
- The status register, when latched, contains the current contents of the Control Word Register and status of the output and null count flag.

## Internal Block Diagram



Figure 5. Internal Block Diagram of a Counter

## System Interface



#### Control Word format



#### 8254 Programming

- Each counter is individually programmed by writing a control word, followed by the initial count.
- The control word allows the programmer to select the counter, mode of operation, binary or BCD count and type of operation (read/write).

## WRITE Operation

$$\overline{CS} = 0$$
  $\overline{RD} = 1$   $\overline{WR} = 0$ 

- Control Word to Control register
- Initial count must follow the count format specified in the Control Word (least significant byte only, most significant byte only, or least significant byte and then most significant byte).

## **READ Operation**

$$\overline{CS} = 0$$
 ,  $\overline{RD} = 0$  ,  $\overline{WR} = 1$ 

Three Possible Methods to read counters

- Simple Read Operation,
- Counter Latch Command,
- Read Back Command.

Note: Two I/O read operations have to be performed to get first Lower Byte and then higher byte of count.

#### Simple Read Operation:

After inhibiting counter using GATE or CLK input we can read count

#### Counter Latch Command:

$$A_1, A_0 = 11; CS = 0; RD = 1; WR = 0$$
 $D_7 \quad D_6 \quad D_5 \quad D_4 \quad D_3 \quad D_2 \quad D_1 \quad D_0$ 
 $SC1 \quad SC0 \quad 0 \quad 0 \quad X \quad X \quad X \quad X$ 

D5 D4 = 0 0 Designates the counter latch command SC1 SC2 = Specify counter to be latched.

X – Don't care bits must be 0 to ensure compatibility with future Intel products.

#### **Read Back Command:**



Figure 10. Read-Back Command Format

## Status Byte

| D <sub>7</sub>                   | D <sub>6</sub>   | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|----------------------------------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|
| Output                           | Null<br>Count    | RW1            | RW0            | M2             | М1             | МО             | BCD            |
| D <sub>7</sub> 1                 | 1 = OU<br>0 = OU |                | 277.127.00     |                |                |                |                |
| D <sub>6</sub> 1                 | 1 = Nu<br>0 = Co |                | 77:42 (        | for r          | eadir          | ng             |                |
| D <sub>5</sub> -D <sub>0</sub> ( | Counter<br>7)    | progr          | amme           | d mo           | de (           | see            | Figure         |

## Read-back command example

| Command        |       |       |       | t     |       |       | Description | Decult                                  |                                                       |  |  |
|----------------|-------|-------|-------|-------|-------|-------|-------------|-----------------------------------------|-------------------------------------------------------|--|--|
| D <sub>7</sub> | $D_6$ | $D_5$ | $D_4$ | $D_3$ | $D_2$ | $D_1$ | $D_0$       | Description                             | Result                                                |  |  |
| 1              | 1     | 0     | 0     | 0     | 0     | 1     | 0           | Read back count and status of Counter 0 | Count and status latched for Counter 0                |  |  |
| 1              | 1     | 1     | 0     | 0     | 1     | 0     | 0           | Read back status of Counter 1           | Status latched for Counter 1                          |  |  |
| 1              | 1     | 1     | 0     | 1     | 1     | 0     | 0           | Read back status of Counters 2, 1       | Status latched for Counter 2, but not Counter 1       |  |  |
| 1              | 1     | 0     | 1     | 1     | 0     | 0     | 0           | Read back count of Counter 2            | Count latched for Counter 2                           |  |  |
| 1              | 1     | 0     | 0     | 0     | 1     | 0     | 0           | Read back count and status of Counter 1 | Count latched for Counter 1, but not status           |  |  |
| 1              | 1     | 1     | 0     | 0     | 0     | 1     | 0           | Read back status of Counter 1           | Command ignored, status already latched for Counter 1 |  |  |

# Interleaved Read and Write Operations:

Valid sequence for read and write of the same counter set for two byte count:

- 1. Read least significant byte,
- 2. Write new least significant byte,
- 3. Read most significant byte,
- 4. Write new most significant byte.

## Modes of 8254

#### Six Different Modes

- Mode 0: Interrupt On Terminal Count
- Mode 1: Hardware Retriggerable One-shot
- Mode 2: Rate Generator
- Mode 3: Square Wave Mode
- Mode 4: Software Triggered Strobe
- Mode 5: Hardware Triggered Strobe (Retriggerable)

## Applications of 8254

- Real time clock
- Event-counter
- Digital one-shot
- Programmable rate generator
- Square wave generator
- Binary rate multiplier
- Complex waveform generator
- Complex motor controller

#### References

- Microprocessors and Interfacing by Douglas V. Hall, TMH Publication.
- Intel 8254 data sheet (www.datasheetcatalog.com)